<template>
  <div class="page">
      <el-form size="small" :inline="true" class="query-form" ref="searchForm" :model="searchForm" @keyup.enter.native="refreshList()" @submit.native.prevent>
            <!-- 搜索框-->
         <!-- <el-form-item prop="applyuser.id">
            <user-select :limit='1' size="small" placeholder="请选择申请人" :value="searchForm.applyuser.id" @getValue='(value) => {searchForm.applyuser.id=value}'></user-select>
         </el-form-item>
         <el-form-item prop="company.id">
            <SelectTree
                  ref="company.id"
                  :props="{
                      value: 'id',             // ID字段名
                      label: 'name',         // 显示名称
                      children: 'children'    // 子级字段名
                    }"
                  size="small" 
                  placeholder="请选择所属公司"
                  :url="`/sys/office/treeData?type=2`"
                  :value="searchForm.company.id"
                  :clearable="true"
                  :accordion="true"
                  @getValue="(value) => {searchForm.company.id=value}"/>
         </el-form-item> -->
         <el-form-item prop="applydate">
               <el-date-picker
                    v-model="searchForm.applydate"
                    type="daterange"
                    size="small"
                    align="right"
                    value-format="yyyy-MM-dd hh:mm:ss"
                    unlink-panels
                    ge-separator="-"
                    start-placeholder="申请开始日期"
                    end-placeholder="结束日期">
                 </el-date-picker>
         </el-form-item>
         <!-- <el-form-item prop="depart.id">
            <SelectTree
                  ref="depart.id"
                  :props="{
                      value: 'id',             // ID字段名
                      label: 'name',         // 显示名称
                      children: 'children'    // 子级字段名
                    }"
                  size="small" 
                  placeholder="请选择所属部门"
                  :url="`/sys/office/treeData?type=2`"
                  :value="searchForm.depart.id"
                  :clearable="true"
                  :accordion="true"
                  @getValue="(value) => {searchForm.depart.id=value}"/>
         </el-form-item> -->
         <el-form-item prop="supplie.id">
            <GridSelect
                    title="选择客户名称"
                    placeholder="请选择客户名称"
                    labelName = 'name'
                    labelValue = 'id'
                    :value = "searchForm.supplie.id"
                    :limit="1"
                    size="small" 
                    @getValue='(value) => {searchForm.supplie.id=value}'
                    :columns="[
                    {
                      prop: 'name',
                      label: '全称'
                    },
                    {
                      prop: 'simplename',
                      label: '简称'
                    },
                    {
                      prop: 'code',
                      label: '社会统一信用代码'
                    },
                    {
                      prop: 'taxno',
                      label: '纳税人识别号'
                    },
                    {
                      prop: 'tel',
                      label: '联系电话'
                    },
                    {
                      prop: 'address',
                      label: '地址'
                    },
                    {
                      prop: 'contactname',
                      label: '联系人'
                    },
                    {
                      prop: 'contactphone',
                      label: '联系人电话'
                    }
                    ]"
                    :searchs="[
                    {
                      prop: 'name',
                      label: '全称'
                    },
                    {
                      prop: 'simplename',
                      label: '简称'
                    },
                    {
                      prop: 'code',
                      label: '社会统一信用代码'
                    },
                    {
                      prop: 'taxno',
                      label: '纳税人识别号'
                    },
                    {
                      prop: 'tel',
                      label: '联系电话'
                    },
                    {
                      prop: 'email',
                      label: '邮箱'
                    },
                    {
                      prop: 'address',
                      label: '地址'
                    },
                    {
                      prop: 'contactname',
                      label: '联系人'
                    },
                    {
                      prop: 'contactphone',
                      label: '联系人电话'
                    }
                    ]"
                    dataListUrl="/dlyrl.oa.supplier/oaSupplier/list"
                    entityBeanName="oaSupplier"
                    queryEntityUrl="/dlyrl.oa.supplier/oaSupplier/queryById">
                  </GridSelect>
         </el-form-item>
          <el-form-item style="float: right">
            <el-button type="primary" @click="refreshList()" size="small">查询</el-button>
            <el-button @click="resetSearch()" size="small">重置</el-button>
          </el-form-item>
      </el-form>
        <!-- 导入导出-->
        <el-dialog  title="导入Excel" :visible.sync="isImportCollapse">
          <el-form :inline="true" v-show="isImportCollapse"  class="query-form" ref="importForm">
             <el-form-item>
              <el-button type="default" @click="downloadTpl()" size="small">下载模板</el-button>
             </el-form-item>
             <el-form-item prop="loginName">
                <el-upload
                  class="upload-demo"
                  :action="`${this.$http.BASE_URL}/dlyrl/oa/applyinvoice/oaApplyInvoice/import`"
                  :on-success="uploadSuccess"
                   :show-file-list="true">
                  <el-button size="small" type="primary">点击上传</el-button>
                  <div slot="tip" class="el-upload__tip">只允许导入“xls”或“xlsx”格式文件！</div>
                </el-upload>
            </el-form-item>
          </el-form>
      </el-dialog>
      <div class="bg-white top">
      <el-row>
        <!-- <el-button v-if="hasPermission('dlyrl:oa:applyinvoice:oaApplyInvoice:add')" type="primary" size="small" icon="el-icon-plus" @click="add()">新建</el-button> -->
        <!-- <el-button v-if="hasPermission('dlyrl:oa:applyinvoice:oaApplyInvoice:edit')" type="warning" size="small" icon="el-icon-edit-outline" @click="edit()" -->
         <!-- :disabled="dataListSelections.length != 1" plain>修改</el-button> -->
        <!-- <el-button v-if="hasPermission('dlyrl:oa:applyinvoice:oaApplyInvoice:del')" type="danger"   size="small" icon="el-icon-delete" @click="del()"
                  :disabled="dataListSelections.length <= 0" plain>删除
        </el-button> -->
        <el-button-group class="pull-right">
            <el-button v-if="hasPermission('dlyrl:oa:applyinvoice:oaApplyInvoice:import')" type="default" size="small" icon="el-icon-upload2" title="导入" @click="isImportCollapse = !isImportCollapse, isSearchCollapse=false"></el-button>
            <el-button v-if="hasPermission('dlyrl:oa:applyinvoice:oaApplyInvoice:export')" type="default" size="small" icon="el-icon-download" title="导出" @click="exportExcel()"></el-button>
            <el-button
              type="default"
              size="small"
              icon="el-icon-refresh"
              @click="refreshList">
            </el-button>
        </el-button-group>
      </el-row>
    <el-table
      :data="dataList"
      :cell-style="cellStyle"
      :row-class-name="tableRowClassName"
      :header-cell-class-name="cellHeadStyle"
      style="width:100%; border:1px solid #d6cfe2;"
      @selection-change="selectionChangeHandle"
      @sort-change="sortChangeHandle"
      v-loading="loading"
      size="small"
      height="calc(100% - 80px)"
      class="table">
            <!-- @expand-change="detail" -->
      <el-table-column
        type="selection"
        header-align="center"
        align="center"
        width="50">
      </el-table-column>
      <!-- <el-table-column type="expand">
        eslint-disable-next-line
      <template slot-scope="scope">
      <el-tabs>
            </el-tabs>
      </template>
      </el-table-column> -->
      <el-table-column
        prop="applyuser.name"
        show-overflow-tooltip
        align="center"
        label="申请人">
            <!-- <template slot-scope="scope">
              <el-link  type="primary" :underline="false" v-if="hasPermission('dlyrl:oa:applyinvoice:oaApplyInvoice:edit')" @click="edit(scope.row.id)">{{scope.row.applyuser.name}}</el-link>
              <el-link  type="primary" :underline="false" v-else-if="hasPermission('dlyrl:oa:applyinvoice:oaApplyInvoice:view')"  @click="view(scope.row.id)">{{scope.row.applyuser.name}}</el-link>
              <span v-else>{{scope.row.applyuser.name}}</span>
            </template> -->
      </el-table-column>
      <el-table-column
        prop="company.name"
        show-overflow-tooltip
        align="center"
        label="所属公司">
      </el-table-column>
    <el-table-column
        prop="applydate"
        show-overflow-tooltip
        align="center"
        label="申请时间">
      </el-table-column>
      <el-table-column
        prop="depart.name"
        show-overflow-tooltip
        align="center"
        label="所属部门">
      </el-table-column>
      <el-table-column
        prop="supplie.name"
        show-overflow-tooltip
        align="center"
        label="客户名称">
      </el-table-column>
    <el-table-column
        prop="incoicetype"
        show-overflow-tooltip
        align="center"
        label="开票类型">
        <template slot-scope="scope">
              {{ $dictUtils.getDictLabel("lhinvoice_type", scope.row.incoicetype, '-') }}
        </template>
      </el-table-column>
    <el-table-column
        prop="taxno"
        show-overflow-tooltip
        width="150"
        align="center"
        label="客户纳税人识别号">
      </el-table-column>
    <el-table-column
        prop="taxaddress"
        show-overflow-tooltip
        align="center"
        min-width="120"
        label="纳税人地址">
      </el-table-column>
    <el-table-column
        prop="bankname"
        show-overflow-tooltip
        align="center"
        min-width="120"
        label="开户行名称">
      </el-table-column>
    <el-table-column
        prop="phone"
        show-overflow-tooltip
        align="center"
        label="联系电话">
      </el-table-column>
    <el-table-column
        prop="bankno"
        show-overflow-tooltip
        align="center"
        label="账号">
      </el-table-column>
    <el-table-column
        prop="projectmoney"
        show-overflow-tooltip
        align="center"
        label="项目金额">
      </el-table-column>
    <el-table-column
        prop="invoicemoney"
        show-overflow-tooltip
        align="center"
        label="开票金额">
      </el-table-column>
    <el-table-column
        prop="money"
        show-overflow-tooltip
        align="center"
        label="金额">
      </el-table-column>
    <el-table-column
        prop="projectname"
        show-overflow-tooltip
        align="center"
        label="项目名称">
      </el-table-column>
    <el-table-column
        prop="projectcode"
        show-overflow-tooltip
        align="center"
        label="项目编号">
      </el-table-column>
      <!-- <el-table-column
        header-align="center"
        align="center"
        fixed="right"
        :key="Math.random()"
        width="200"
        label="操作">
        <template  slot-scope="scope">
          <el-button v-if="hasPermission('dlyrl:oa:applyinvoice:oaApplyInvoice:view')" type="text" icon="el-icon-view" size="mini" @click="view(scope.row.id)">查看</el-button>
          <el-button v-if="hasPermission('dlyrl:oa:applyinvoice:oaApplyInvoice:edit')" type="text" icon="el-icon-edit" size="mini" @click="edit(scope.row.id)">修改</el-button>
          <el-button v-if="hasPermission('dlyrl:oa:applyinvoice:oaApplyInvoice:del')" type="text"  icon="el-icon-delete" size="mini" @click="del(scope.row.id)">删除</el-button>
        </template>
      </el-table-column> -->
    </el-table>
    <el-pagination
      @size-change="sizeChangeHandle"
      @current-change="currentChangeHandle"
      :current-page="pageNo"
      :page-sizes="[10, 20, 50, 100]"
      :page-size="pageSize"
      :total="total"
      background
      layout="total, sizes, prev, pager, next, jumper">
    </el-pagination>
    </div>
        <!-- 弹窗, 新增 / 修改 -->
    <!-- <OaApplyInvoiceForm  ref="oaApplyInvoiceForm" @refreshDataList="refreshList"></OaApplyInvoiceForm> -->
  </div>
</template>

<script>
  import tableStyles from '../../../../../utils/mixins'
  import OaApplyInvoiceForm from './OaApplyInvoiceForm'
  import UserSelect from '@/components/userSelect'
  import SelectTree from '@/components/treeSelect/treeSelect.vue'
  import GridSelect from '@/components/gridSelect'
  export default {
    mixins: [tableStyles],
    data () {
      return {
        searchForm: {
          applyuser: {
            id: ''
          },
          company: {
            id: ''
          },
          applydate: '',
          depart: {
            id: ''
          },
          supplie: {
            id: ''
          }
        },
        dataList: [],
        pageNo: 1,
        pageSize: 10,
        total: 0,
        orderBy: '',
        dataListSelections: [],
        isImportCollapse: false,
        loading: false
      }
    },
    components: {
      UserSelect,
      SelectTree,
      GridSelect,
      OaApplyInvoiceForm
    },
    activated () {
      this.refreshList()
    },
    methods: {
      // 获取数据列表
      refreshList () {
        this.searchForm.company.id=this.$store.state.user.companyId;
        this.loading = true
        this.$http({
          url: '/dlyrl/oa/applyinvoice/oaApplyInvoice/list',
          method: 'get',
          params: {
            'pageNo': this.pageNo,
            'pageSize': this.pageSize,
            'orderBy': this.orderBy,
            // 'company':this.$store.state.user.companyId,
            beginApplydate: this.searchForm.applydate[0],
            endApplydate: this.searchForm.applydate[1],
            ...this.lodash.omit(this.searchForm, 'applydate')
          }
        }).then(({data}) => {
          if (data && data.success) {
            this.dataList = data.page.list
            this.total = data.page.count
            this.loading = false
          }
        })
      },
      // 每页数
      sizeChangeHandle (val) {
        this.pageSize = val
        this.pageNo = 1
        this.refreshList()
      },
      // 当前页
      currentChangeHandle (val) {
        this.pageNo = val
        this.refreshList()
      },
      // 多选
      selectionChangeHandle (val) {
        this.dataListSelections = val
      },

    // 排序
      sortChangeHandle (obj) {
        if (obj.order === 'ascending') {
          this.orderBy = obj.prop + ' asc'
        } else if (obj.order === 'descending') {
          this.orderBy = obj.prop + ' desc'
        } else {
          this.orderBy = ''
        }
        this.refreshList()
      },
    //   // 新增
    //   add () {
    //     this.$refs.oaApplyInvoiceForm.init('', 'add')
    //   },
    //   // 修改
    //   edit (id) {
    //     id = id || this.dataListSelections.map(item => {
    //       return item.id
    //     })[0]
    //     this.$refs.oaApplyInvoiceForm.init(id, 'edit')
    //   },
    //   // 查看
    //   view (id) {
    //     this.$refs.oaApplyInvoiceForm.init(id, 'view')
    //   },
    //   // 删除
    //   del (id) {
    //     let ids = id || this.dataListSelections.map(item => {
    //       return item.id
    //     }).join(',')
    //     this.$confirm(`确定删除所选项吗?`, '提示', {
    //       confirmButtonText: '确定',
    //       cancelButtonText: '取消',
    //       type: 'warning'
    //     }).then(() => {
    //       this.loading = true
    //       this.$http({
    //         url: '/dlyrl/oa/applyinvoice/oaApplyInvoice/delete',
    //         method: 'delete',
    //         params: {'ids': ids}
    //       }).then(({data}) => {
    //         if (data && data.success) {
    //           this.$message.success(data.msg)
    //           this.refreshList()
    //         }
    //         this.loading = false
    //       })
    //     })
    //   },
    //  // 查看详情
    //   detail (row) {
    //     this.$http.get(`/dlyrl/oa/applyinvoice/oaApplyInvoice/queryById?id=${row.id}`).then(({data}) => {
    //       this.dataList.forEach((item, index) => {
    //         if (item.id === row.id) {
    //         }
    //       })
    //     })
    //   },
      // 导入成功
      uploadSuccess (res, file) {
        if (res.success) {
          this.$message.success({dangerouslyUseHTMLString: true,
            message: res.msg})
        } else {
          this.$message.error(res.msg)
        }
      },
      // 下载模板
      downloadTpl () {
        this.$utils.download('/dlyrl/oa/applyinvoice/oaApplyInvoice/import/template')
      },
      exportExcel () {
        let params = {
          beginApplydate: this.searchForm.applydate[0],
          endApplydate: this.searchForm.applydate[1],
          ...this.lodash.omit(this.searchForm, 'applydate')
        }
        this.$utils.download('/dlyrl/oa/applyinvoice/oaApplyInvoice/export', params)
      },
      resetSearch () {
        this.$refs.searchForm.resetFields()
        this.refreshList()
      }
    }
  }
</script>